// Copyright 2020 The casbin Authors. All Rights Reserved.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
//      http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.

import React from "react";
import * as Setting from "../Setting";
import * as NodeBackend from "../backend/NodeBackend";
import "./rightFavourite.css"
import i18next from "i18next";

class RightLatestNodeBox extends React.Component {
  constructor(props) {
    super(props);
    this.state = {
      classes: props,
      info: null,
      limit: 20
    };
  }

  componentDidMount() {
    this.getLatestNodes();
  }

  getLatestNodes() {
    NodeBackend.getLatestNode(this.state.limit)
      .then((res) => {
        this.setState({
          info: res.data,
        });
      });
  }

  renderNodes(node) {
    return (
      <a href={`/go/${node?.id}`} className="item_node">{node?.name}</a>
    )
  }

  render() {
    return (
      <div className="box">
        <div className="cell">
          <div className="fr"></div>
          <span className="fade">{i18next.t("bar:Recently added nodes")}</span></div>
        <div className="inner">
          {
            this.state.info?.map((node) => {
              return this.renderNodes(node);
            })
          }
        </div>
      </div>
    )
  }
}

export default RightLatestNodeBox;
